package com.atguigu.gmall.realtime.function;

import com.atguigu.gmall.realtime.util.AtguiguUtil;
import org.apache.flink.table.annotation.DataTypeHint;
import org.apache.flink.table.annotation.FunctionHint;
import org.apache.flink.table.functions.TableFunction;
import org.apache.flink.types.Row;

import java.util.Set;

/**
 * @Author lzc
 * @Date 2023/2/17 09:58
 */
// 指定下每列的列名和类型
@FunctionHint(output = @DataTypeHint("row<keyword string>"))
public class KwSplit extends TableFunction<Row> {
    // 约定的方法
    // 返回值: 必须是 void
    // 方法名: 必须是 eval
    // 参数列表: 根据实际情况
    // "华为手机 256g 手机"
    public void eval(String kw) {
        if (kw == null) {
            return;
        }
        Set<String> keywords = AtguiguUtil.mySplit(kw);
        for (String keyword : keywords) {
            collect(Row.of(keyword));
        }
    }
}
